<!DOCTYPE html>
<html lang="en">

<head>
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>Document</title>
    <script src="js/vue.js"></script>
</head>

<body>
    <div id="box">
        <!-- <navbar @myevent="isShow=!isShow"></navbar> -->

        <!-- 用插槽方法 -->
        <navbar>
            <button @click="isShow=!isShow">显示/隐藏</button>
        </navbar>
        <sidebar v-show="isShow"></sidebar>
    </div>
    <script>
        Vue.component("navbar", {
            //     template: `
            //         <div style="background:skyblue">
            //             导航栏--> <button @click="handleClick">显示/隐藏</button>
            //         </div>  
            //    `,
            //     methods: {
            //         handleClick() {
            //             this.$emit("myevent")
            //         }
            //     }
            // })

            // 组件中使用slot插槽来存放实例中的按钮
            template: `
                <div style="background:skyblue">
                    导航栏-<slot></slot>
                </div>  
           `
        })

        Vue.component("sidebar", {
            template: `
                <div>
                    <ul style="width:100px;background:#ccc;list-style: none;">
                        <li>首页</li>
                        <li>商品</li>
                        <li>详情</li>
                    </ul>
                </div>  
           `
        })
        var vm = new Vue({
            el: "#box",
            data: {
                isShow: true
            }
        })
    </script>
</body>

</html>